﻿//746.使用最小花费爬楼梯
//数组的每个下标作为一个阶梯，第 i 个阶梯对应着一个非负数的体力花费值 cost[i]（下标从 0 开始）。
//每当你爬上一个阶梯你都要花费对应的体力值，一旦支付了相应的体力值，你就可以选择向上爬一个阶梯或者爬两个阶梯。
//请你找出达到楼层顶部的最低花费。在开始时，你可以选择从下标为 0 或 1 的元素作为初始阶梯。

using Math = System.Math;

namespace LeetCode.DynamicProgramming
{
    public class Solution
    {
        public int MinCostClimbingStairs(int[] cost)
        {
            if (cost.Length == 2 || cost.Length == 1)
            {
                return Math.Min(cost[0], cost[1]);
            }

            int result = 0;

            for (int i = 2; i < cost.Length; i++)
            {
                result = Math.Min(cost[i] + cost[i - 2], cost[i - 1]);
                cost[i] = cost[i] + Math.Min(cost[i - 2], cost[i - 1]);
            }

            return result;
        }
    }
}
